

# Travail pratique #1 INF1600 - Architecture du processeur

Trimestre: automne 2018

Équipier1: Nanor Janjikian (1901777) Équipier2 : Yasmina Abou-Nakkoul (1897266)

**Équipe**: 11 (groupe B1)

Presenté à :

Ulrich Dah-Achinanon

École polytechnique de Montréal 8 octobre 2018

# Exercice 1 : Révision de logique et arithmétique numérique

1. Les valeurs décimales pour les nombres entiers signés suivants :

Pour convertir les nombres suivants en décimal, nous devons nous rappeler que le complément à deux consiste à renverser le nombre bit par bit et à ajouter un 1. De plus, nous devons vérifier le signe de chaque nombre.

# a. 1100 1101 (binaire):

- Tout d'abord, nous renversons les bits : (00110010)<sub>2</sub>
- Nous ajoutons un 1 : (00110011)<sub>2</sub>
- Ensuite, nous observons que le nombre binaire est négatif :  $-(00110011)_2$
- Nous multiplions chaques bits par son exposant de 2 :  $-(2^5 + 2^4 + 2^1 + 2^0) = -51$

# b. 0110 1011 (binaire):

- Nous observons que le nombre binaire est positif
- Nous multiplions chaques bits par son exposant de 2 :  $(2^0 + 2^1 + 2^3 + 2^5 + 2^6)$  = **107**

# c. 5726 (octal):

- 1 chiffre est représenté par 3 bits pour transformer le nombre en binaire : (101 111 010 110)<sub>2</sub>
- Le nombre est négatif et nous renversons les bits :  $-(010000101001)_2$
- Nous ajoutons un 1 : (0100 0010 1010)<sub>2</sub>
- Nous multiplions chaques bits par son exposant de 2 :  $-(2^1 + 2^3 + 2^5 + 2^{10})$  = -1066

# d. FADE (hexadécimal, 16 bits):

- 1 chiffre est représenté par 4 bits pour transformer le nombre en binaire :  $(1111\ 1010\ 1101\ 1110)_2$
- Le nombre est négatif et nous renversons les bits : (0000 0101 0010 0001)<sub>2</sub>
- Nous ajoutons un 1 : (0000 0101 0010 0010)<sub>2</sub>
- Nous multiplions chaques bits par son exposant de 2 :  $-(2^1 + 2^5 + 2^8 + 2^{10})$  = -1314

#### e. 1000 0000 (binaire):

- Tout d'abord, nous renversons les bits : (011111111)<sub>2</sub>
- Nous ajoutons un 1 : (10000000)<sub>2</sub>
- Ensuite, nous observons que le nombre binaire est négatif : -(10000000),
- Nous multiplions chaques bits par son exposant de 2 :  $-(2^7)$  = -128

# 2. Dans le tableau suivant, nous allons indiquer les bases possibles pour les numéros :

| ID | Numéros   | BIN | ОСТ | DEC | HEX |
|----|-----------|-----|-----|-----|-----|
| a. | 2586      |     |     | Х   | Х   |
| b. | 0000 0000 | Х   | Х   | Х   | Х   |
| C. | 11111     | Х   | Х   | Х   | Х   |
| d. | 514       |     | Х   | Х   | Х   |

| e. | A626 |  | Х |
|----|------|--|---|
|    |      |  |   |

X : bases possibles pour les numéros

# 3. En langage C:

$$y = x & (5 << 4)$$

L'instruction de la ligne précédente décale le nombre binaire de 5, soit  $(101)_2$ , de 4 bits vers la gauche. Ensuite, elle compare tous les bits de x avec  $(1010000)_2$ : 5<<4. La porte ET « & » fait une comparaison bit à bit entre les deux entiers binaires. En effet, si l'un des 2 bits comparés équivaut à 0, alors le bit de retour sera 0. Toutefois, si les 2 bits sont à 1, le bit de retour sera 1. Finalement, le résultat obtenu par cette comparaison sera mis dans la variable y.

4. La représentation binaire signée (complément à deux) 16-bit et en hexadécimal 16-bit des nombres entiers en base de décimale suivants :

# a. -9876:

- En base de 2 :- (0010 0110 1001 0100) ,
- Nous inversons les bits : (1101 1001 0110 1011) ,
- Nous ajoutons un 1 : (1101 1001 0110 1100) 2
- Nous faisons l'association des bits avec les valeurs hexadécimales :  $(D96C)_{16}$

#### b. -64 :

- En base de 2 : (0000 0000 0100 0000) 2
- Nous inversons les bits : (1111 1111 1011 1111) 2
- Nous ajoutons un 1 : (1111 1111 1100 0000) 2
- Nous faisons l'association des bits avec les valeurs hexadécimales :  $(FFC0)_{16}$

#### c. 12345:

- En base de 2 : (0011 0000 0011 1001) <sub>2</sub>
- Nous faisons l'association des bits avec les valeurs hexadécimales : (3039)<sub>16</sub>
- 5. Effectuons les opérations arithmétiques suivantes sur 8 bits et indiquons s'il y a un débordement signé, en plus de fournir le résultat au format hexadécimal.

# a. 8B + 6A:

- 8B: 1000 1011 - 6A: 0110 1010

 $\rightarrow$  8B + 6A = (1000 1011)<sub>2</sub> + (0110 1010)<sub>2</sub> = (1111 0101)<sub>2</sub> = (F5)<sub>16</sub>

La réponse (F5 = -11) de l'opération n'a pas de débordement parce que les deux opérandes ont des signes opposés.

#### b. 52 + 49:

- 52:0101 0010

- 49:0100 1001

 $\rightarrow$  52 + 49 = (0101 0010)<sub>2</sub> + (0100 1001)<sub>2</sub> = (1001 1011)<sub>2</sub> = (9B)<sub>16</sub>

La réponse (9B = -101) de l'opération a un débordement parce que les deux opérandes ont des signes positifs et le résultat est négatif. En effet, l'addition de deux nombres positifs doit avoir un résultat positif.

# 6. a. La valeur décimale de l'entier non signé en big-endian :

Les octets 2 à 8 de la séquence sont: C2, BB, 38 et A0.

La valeur décimale de l'entier non signé en <u>big-endian</u> est donc la conversion de (C2BB38A0)<sub>16</sub>  $\rightarrow$  (3267049632)<sub>10</sub>.

# b. La valeur décimale de l'entier non signé en little-endian :

La valeur décimale de l'entier non signé en <u>little-endian</u> est la conversion de  $(A038BBC2)_{16} \rightarrow (2688072642)_{10}$ .

|      | Vitesse de rotation | 5400 RPM       |
|------|---------------------|----------------|
| Zone | Pistes/Zone         | Secteurs/Piste |
| 1    | 624                 | 792            |
| 2    | 1424                | 780            |
| 3    | 1680                | 760            |
| 4    | 1815                | 720            |

**Exercice 2: Disque dur** 

#### a) L'espace total sur le disque dur (512 B/secteur) :

D'un côté, pour calculer l'espace totale sur le disque dur, nous pouvons faire le calcul de l'espace de chaque zone pour ensuite faire l'addition et trouver l'espace total. D'un autre côté, nous pouvons faire le calcul de l'espace total sur le disque directement en additionnant le produit des zones entre Pistes/Zone et Secteurs/Piste.

$$[(624 * 792 + 1424 * 780 + 1680 * 760 + 1815 * 720) * 512]/2^{30} = 2 GiB$$

#### b) Le taux de lecture moyenne :

Tout d'abord, nous devons trouver le nombre moyen de secteurs par piste.

$$(792 + 780 + 760 + 720) / 4 = 763$$
 secteurs/piste en moyenne

Le taux de lecture :

$$5400 / 60 * 763 * 512 * 8 / 2^{20} = 268,24 Mb/s$$

c) taux de lecture moyenne effective si le disque dur est connecté avec un bus PCIe de vitesse 4000 Mb/s.

Le disque dur étant connecté au bus PCIe de vitesse 4000 Mb/s, nous indique que l'interface n'est pas limitante par rapport à la vitesse de lecture moyenne du disque parce que son taux de transfert est très supérieur du taux de lecture moyenne (4000 Mb/s > 268 Mb/s). Alors, le taux de transfert reste le même, soit de 268 Mb/s.

# d) Changeriez-vous les résultats précédents si l'information sur le nombre de surfaces était disponible ?

Si le nombre de surfaces est plus grand que 1, il sera possible de lire plusieurs pistes en même temps. Ceci veut dire que le taux de transfert est proportionnel au nombre de surfaces qu'on peut lire à la fois.

Le résultat pourrait effectivement changer si l'information sur le nombre de surfaces était disponible.

# **Exercice 3: Description RTN La notation RTN**

Écrivez en notation RTN abstraite les instructions hypothétiques suivantes :

Nous savons que :

```
op<4..0> := IR<31..27>
a<4..0> := IR<26..22>
b<4..0> := IR<21..17>
c<4..0> := IR<16..12>
k<16..0> := IR<16..0>
```

# 1. SUBMUL Ra, Rb, k:

- Cette instruction soustrait le contenu du registre numéro b du registre numéro a puis multiplie le tout par huit et met le résultat dans le registre numéro a
- Précisez la valeur de la constante k
- Le code d'opération de cette instruction est 5

```
(IR<31..27> = 5) \rightarrow R[IR<16..12>] \leftarrow ((R[IR<26..22>] - R[IR<21..17>])*R[IR<16..0>]);
```

La valeur de la constante k est 8 : IR<16..0>.

# 2. DECREM Ra, Rb:

- Cette instruction décrémente les registres numéro a et b et même temps
- Le code d'opération de cette instruction est 13

```
(IR<31..27> = 13) \rightarrow R[IR<16..12>] \leftarrow (R[IR<26..22>] -1) : R[IR<21..17>] \leftarrow (R[IR<21..17>] -1);
```

# Exercice 4: Architecture d'un microprocesseur

Soit la microarchitecture du processeur 32-bit simplifié suivant :



# 1. Soit l'instruction : r1 ← Memoire2 [r3] + r3 :

a) Écrivez un encodage possible (en hexadécimal) de l'instruction. Inventez l'opcode au besoin.

| Bits         | 3124                | 2321 | 2018 | 1715    | 1413    | 120              |
|--------------|---------------------|------|------|---------|---------|------------------|
| Valeur       | 0001 1011           | 001  | 011  | 000     | 00      | 0 0000 0000 0000 |
| Commentaires | opcode (arbitraire) | r1   | r3   | Inutile | Inutile | Inutile          |

b) Écrivez le RTN concret des macro-instructions permettant d'exécuter l'instruction de haut niveau avec la microarchitecture proposée.

 $T \leftarrow R[IR < 20...18 >];$ 

 $T \leftarrow M\acute{e}moire2[T];$ 

 $R[IR<23...21>] \leftarrow T + R[IR<20...18>];$ 

c)

|                    | SIGNAUX DE CONTRÔLE |            |   |   |   |   |   |              |           |         |                |
|--------------------|---------------------|------------|---|---|---|---|---|--------------|-----------|---------|----------------|
| Micro instructions | Α                   | B<br>(bin) | С | D | Е | F | G | UAL<br>(hex) | ecrireEIP | ecrireT | ecrireRegistre |
| T ← R[IR<2018>]    | 0                   | 0b01       | 0 | 0 | 1 | 0 | 0 | 0x0A         | 0         | 1       | 0              |

| T ← Mémoire2[T]                  | 0 |      | 0 | 0 | 0 | 1 | 0 | 0x0A | 0 | 1 | 0 |
|----------------------------------|---|------|---|---|---|---|---|------|---|---|---|
| R[IR<2321>] ← T<br>+ R[IR<2018>] | 0 | 0b01 | 0 | 0 | 1 | 0 | 0 | 0x4A | 0 | 0 | 1 |

# 2. Soit l'instruction : r1 <- (Memoire2 [r3] + 0x23) >> r2 :

a) Écrivez un encodage possible (en hexadécimal) de l'instruction. Inventez l'opcode au besoin.

| Bits         | 3124                | 2321 | 2018 | 1715 | 1413    | 120              |
|--------------|---------------------|------|------|------|---------|------------------|
| Valeur       | 0010 1100           | 001  | 011  | 010  | 00      | 0 0000 0010 0011 |
| Commentaires | opcode (arbitraire) | r1   | r3   | r2   | Inutile | 0x23             |

Encodage possible de l'instruction: en big-endian, (0010 1100 0010 1101 0000 0000 0010 0011)<sub>2</sub> équivaut à : (2C2D0023)<sub>16</sub>. En little-endian, l'instruction serait 0x23002D2C, soit l'opposé de l'encodage en big-endian.

b) Écrivez le RTN concret des macro-instructions permettant d'exécuter l'instruction de haut niveau avec la microarchitecture proposée.

 $T \leftarrow R[IR < 20...18 >];$ 

 $T \leftarrow M\acute{e}moire2[T];$ 

 $T \leftarrow T + R[IR < 12...0 >];$ 

 $R[IR<23...21>] \leftarrow T >> R[IR<17...15>];$ 

c)

|                                   | SIGNAUX DE CONTRÔLE |            |   |   |   |   |   |              |           |         |                |
|-----------------------------------|---------------------|------------|---|---|---|---|---|--------------|-----------|---------|----------------|
| Micro instructions                | А                   | B<br>(bin) | С | D | Ε | F | G | UAL<br>(hex) | ecrireEIP | ecrireT | ecrireRegistre |
| T ← R[IR<2018>]                   | 0                   | 0b01       | 0 | 0 | 1 | 0 | 0 | 0x0A         | 0         | 1       | 0              |
| T ← Mémoire2[T]                   | 0                   |            | 0 | 0 | 0 | 1 | 0 | 0x0A         | 0         | 1       | 0              |
| T ← T +<br>R[IR<120>]             | 0                   |            | 0 | 1 | 0 | 0 | 0 | 0x4A         | 0         | 1       | 0              |
| R[IR<2321>] ← T<br>>> R[IR<1715>] | 0                   | 0b10       | 0 | 0 | 1 | 0 | 0 | 0x11         | 0         | 0       | 1              |